﻿using System;
using System.Data;
using System.Configuration;
using System.Linq;
using System.Web;
using System.Xml.Linq;
using MySql.Data.MySqlClient;
using MySql.Data.Types;
using System.Data.Sql;
using System.Data.SqlClient;

/// Espacio de nombres para los contenedores
namespace GCon
{

    /// <summary>
    /// Clase contenedora de Nacionalidad
    /// </summary>
    public class Con_Nacionalidad
    {
        /// <summary>
        /// Constructor por defecto
        /// </summary>
        public Con_Nacionalidad()
        {
          
        }

        /// <summary>
        /// Constructor con todos los parametros
        /// </summary>
        public Con_Nacionalidad(String ID_PK, String NOMBRE)
        {
            this._ID_PK = ID_PK;
            this._NOMBRE = NOMBRE;
        }

        /// <summary>
        /// Constructor de copia
        /// </summary>
        /// <param name="otro"></param>
        public Con_Nacionalidad(Con_Nacionalidad otro)
        {
            this._ID_PK = otro._ID_PK;
            this._NOMBRE = otro._NOMBRE;
        }

        /// Getters
        public String Get_ID_PK()
        {
            return this._ID_PK;
        }
        public String Get_NOMBRE()
        {
            return this._NOMBRE;
        }

        /// Setters
        public void Set_ID_PK(String parametro)
        {
            this._ID_PK = parametro;
        }
        public void Set_NOMBRE(String parametro)
        {
            this._NOMBRE = parametro;
        }

        /// <summary>
        /// Procedimiento de carga.
        /// Recupera de la BBDD la Nacionalidad con Id = IdNacionalidad.
        /// </summary>
        /// <param name="IdNacionalidad"></param>
        public void CargaNacionalidad(int IdNacionalidad)
        {
            MySqlConnection oConexion;
            MySqlDataAdapter oAdaptador;
            DataSet ds;
            String llamada;

            oConexion = new MySqlConnection();
            oConexion.ConnectionString = "Server=localhost;Database=MERYLAND;Uid=root;Pwd=MERYLAND;";
            oConexion.Open();

            llamada = "CALL CargaNacionalidad ( '" + IdNacionalidad + "' );";
            oAdaptador = new MySqlDataAdapter(llamada, oConexion);
            ds = new DataSet();
            oAdaptador.Fill(ds, "Tabla");
            
            foreach (DataRow dr in ds.Tables[0].Rows)
            {
                this._ID_PK = dr["NACIONALIDAD_ID_PK"].ToString();
                this._NOMBRE = dr["NACIONALIDAD_NOMBRE"].ToString();

            }
            
            oConexion.Close();
        }

        /// <summary>
        /// Procedimiento de inserción.
        /// Inserta en la BBDD una Nacionalidad.
        /// </summary>
        public void InsertaNacionalidad()
        {
            MySqlConnection oConexion;
            MySqlCommand oComando;
            String llamada;

            oConexion = new MySqlConnection();
            oConexion.ConnectionString = "Server=localhost;Database=MERYLAND;Uid=root;Pwd=MERYLAND;";

            llamada = "CALL InsertaNacionalidad ( '" + this._NOMBRE + "' );";
            oComando = new MySqlCommand(llamada, oConexion);
            
            oConexion.Open();
            oComando.ExecuteReader();

            oConexion.Close();
        }

        /// <summary>
        /// Procedimiento de modificación.
        /// Modifica en la BBDD una Nacionalidad.
        /// </summary>
        public void ModificaNacionalidad()
        {
            MySqlConnection oConexion;
            MySqlCommand oComando;
            String llamada;

            oConexion = new MySqlConnection();
            oConexion.ConnectionString = "Server=localhost;Database=MERYLAND;Uid=root;Pwd=MERYLAND;";

            llamada = "CALL ModificaNacionalidad ( '" + this._ID_PK + "','" + this._NOMBRE + "' );";
            oComando = new MySqlCommand(llamada, oConexion);

            oConexion.Open();
            oComando.ExecuteReader();

            oConexion.Close();
        }

        /// <summary>
        /// Procedimiento de eliminación.
        /// Elimina de la BBDD una Nacionalidad.
        /// </summary>
        public void EliminaNacionalidad()
        {
            MySqlConnection oConexion;
            MySqlCommand oComando;
            String llamada;

            oConexion = new MySqlConnection();
            oConexion.ConnectionString = "Server=localhost;Database=MERYLAND;Uid=root;Pwd=MERYLAND;";

            llamada = "CALL EliminaNacionalidad ( '" + this._ID_PK + "' );";
            oComando = new MySqlCommand(llamada, oConexion);

            oConexion.Open();
            oComando.ExecuteReader();

            oConexion.Close();
        }

        ///Atributos
        private String _ID_PK;
        private String _NOMBRE;

    }
}
